.TH std::basic_ios::rdbuf 3 "2024.06.10" "http://cppreference.com" "C++ Standard Libary"
.SH NAME
std::basic_ios::rdbuf \- std::basic_ios::rdbuf

.SH Synopsis
   std::basic_streambuf<CharT, Traits>* rdbuf() const;                             \fB(1)\fP
   std::basic_streambuf<CharT, Traits>* rdbuf( std::basic_streambuf<CharT,         \fB(2)\fP
   Traits>* sb );

   Manages the associated stream buffer.

   1) Returns the associated stream buffer. If there is no associated stream buffer,
   returns a null pointer.
   2) Sets the associated stream buffer to sb. The error state is cleared by calling
   clear(). Returns the associated stream buffer before the operation. If there is no
   associated stream buffer, returns a null pointer.

.SH Parameters

   sb - stream buffer to associate to

.SH Return value

   The associated stream buffer, or a null pointer if there was no associated stream
   buffer.

.SH Exceptions

   May throw implementation-defined exceptions.

.SH Example


// Run this code

 #include <iostream>
 #include <sstream>

 int main()
 {
     std::ostringstream local;
     auto cout_buff = std::cout.rdbuf(); // save pointer to std::cout buffer

     std::cout.rdbuf(local.rdbuf()); // substitute internal std::cout buffer with
         // buffer of 'local' object

     // now std::cout work with 'local' buffer
     // you don't see this message
     std::cout << "some message";

     // go back to old buffer
     std::cout.rdbuf(cout_buff);

     // you will see this message
     std::cout << "back to default buffer\\n";

     // print 'local' content
     std::cout << "local content: " << local.str() << "\\n";
 }

.SH Output:

 back to default buffer
 local content: some message

.SH See also

   set_rdbuf replaces the rdbuf without clearing its error state
             \fI(protected member function)\fP
